home *** CD-ROM | disk | FTP | other *** search
Unknown | 1979-12-31 | 8.3 KB |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was not able to be converted.
This format is not currently supported by dexvert.
Confidence | Program | Detection | Match Type | Support
|
---|
66%
| dexvert
| Compact Compressed (Unix) (archive/compact)
| ext
| Supported |
100%
| file
| MacBinary II, inited, Sat Jan 26 21:37:28 1985, modified Mon Dec 31 19:30:38 1979, 7764 bytes "xleval.c" , at 0x1ed4 490 bytes resource
| default (weak)
| |
99%
| file
| data
| default
| |
100%
| TrID
| MacBinary 2
| default (weak)
| |
100%
| dearkID
| deark: macbinary
| default
| |
100%
| siegfried
| fmt/1762 MacBinary (II)
| default
| |
100%
| lsar
| MacBinary
| default
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 08 78 6c 65 76 61 6c | 2e 63 00 00 00 00 00 00 |..xleval|.c......|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 00 00 00 00 00 00 00 | 00 01 00 00 00 00 00 00 |........|........|
|00000050| 00 00 00 00 00 1e 54 00 | 00 01 ea 98 7f 66 e8 8e |......T.|.....f..|
|00000060| f4 5d ae 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.]......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 75 51 00 00 |........|....uQ..|
|00000080| 2f 2a 20 78 6c 65 76 61 | 6c 20 2d 20 78 6c 69 73 |/* xleva|l - xlis|
|00000090| 70 20 65 76 61 6c 75 61 | 74 6f 72 20 2a 2f 0d 0d |p evalua|tor */..|
|000000a0| 23 69 6e 63 6c 75 64 65 | 20 22 78 6c 69 73 70 2e |#include| "xlisp.|
|000000b0| 68 22 0d 0d 2f 2a 20 65 | 78 74 65 72 6e 61 6c 20 |h"../* e|xternal |
|000000c0| 76 61 72 69 61 62 6c 65 | 73 20 2a 2f 0d 65 78 74 |variable|s */.ext|
|000000d0| 65 72 6e 20 4e 4f 44 45 | 20 2a 78 6c 73 74 61 63 |ern NODE| *xlstac|
|000000e0| 6b 2c 2a 78 6c 65 6e 76 | 2c 2a 78 6c 6e 65 77 65 |k,*xlenv|,*xlnewe|
|000000f0| 6e 76 3b 0d 65 78 74 65 | 72 6e 20 4e 4f 44 45 20 |nv;.exte|rn NODE |
|00000100| 2a 73 5f 6c 61 6d 62 64 | 61 2c 2a 73 5f 6d 61 63 |*s_lambd|a,*s_mac|
|00000110| 72 6f 3b 0d 65 78 74 65 | 72 6e 20 4e 4f 44 45 20 |ro;.exte|rn NODE |
|00000120| 2a 6b 5f 6f 70 74 69 6f | 6e 61 6c 2c 2a 6b 5f 72 |*k_optio|nal,*k_r|
|00000130| 65 73 74 2c 2a 6b 5f 61 | 75 78 3b 0d 65 78 74 65 |est,*k_a|ux;.exte|
|00000140| 72 6e 20 4e 4f 44 45 20 | 2a 73 5f 65 76 61 6c 68 |rn NODE |*s_evalh|
|00000150| 6f 6f 6b 2c 2a 73 5f 61 | 70 70 6c 79 68 6f 6f 6b |ook,*s_a|pplyhook|
|00000160| 3b 0d 65 78 74 65 72 6e | 20 4e 4f 44 45 20 2a 73 |;.extern| NODE *s|
|00000170| 5f 75 6e 62 6f 75 6e 64 | 3b 0d 65 78 74 65 72 6e |_unbound|;.extern|
|00000180| 20 4e 4f 44 45 20 2a 73 | 5f 73 74 64 6f 75 74 3b | NODE *s|_stdout;|
|00000190| 0d 0d 2f 2a 20 66 6f 72 | 77 61 72 64 20 64 65 63 |../* for|ward dec|
|000001a0| 6c 61 72 61 74 69 6f 6e | 73 20 2a 2f 0d 46 4f 52 |laration|s */.FOR|
|000001b0| 57 41 52 44 20 4e 4f 44 | 45 20 2a 78 6c 78 65 76 |WARD NOD|E *xlxev|
|000001c0| 61 6c 28 29 3b 0d 46 4f | 52 57 41 52 44 20 4e 4f |al();.FO|RWARD NO|
|000001d0| 44 45 20 2a 65 76 61 6c | 68 6f 6f 6b 28 29 3b 0d |DE *eval|hook();.|
|000001e0| 46 4f 52 57 41 52 44 20 | 4e 4f 44 45 20 2a 65 76 |FORWARD |NODE *ev|
|000001f0| 66 6f 72 6d 28 29 3b 0d | 46 4f 52 57 41 52 44 20 |form();.|FORWARD |
|00000200| 4e 4f 44 45 20 2a 65 76 | 73 79 6d 28 29 3b 0d 46 |NODE *ev|sym();.F|
|00000210| 4f 52 57 41 52 44 20 4e | 4f 44 45 20 2a 65 76 66 |ORWARD N|ODE *evf|
|00000220| 75 6e 28 29 3b 0d 0d 2f | 2a 20 78 6c 65 76 61 6c |un();../|* xleval|
|00000230| 20 2d 20 65 76 61 6c 75 | 61 74 65 20 61 6e 20 78 | - evalu|ate an x|
|00000240| 6c 69 73 70 20 65 78 70 | 72 65 73 73 69 6f 6e 20 |lisp exp|ression |
|00000250| 28 63 68 65 63 6b 69 6e | 67 20 66 6f 72 20 2a 65 |(checkin|g for *e|
|00000260| 76 61 6c 68 6f 6f 6b 2a | 29 20 2a 2f 0d 4e 4f 44 |valhook*|) */.NOD|
|00000270| 45 20 2a 78 6c 65 76 61 | 6c 28 65 78 70 72 29 0d |E *xleva|l(expr).|
|00000280| 20 20 4e 4f 44 45 20 2a | 65 78 70 72 3b 0d 7b 0d | NODE *|expr;.{.|
|00000290| 20 20 20 20 72 65 74 75 | 72 6e 20 28 73 5f 65 76 | retu|rn (s_ev|
|000002a0| 61 6c 68 6f 6f 6b 2d 3e | 6e 5f 73 79 6d 76 61 6c |alhook->|n_symval|
|000002b0| 75 65 20 3f 20 65 76 61 | 6c 68 6f 6f 6b 28 65 78 |ue ? eva|lhook(ex|
|000002c0| 70 72 29 20 3a 20 78 6c | 78 65 76 61 6c 28 65 78 |pr) : xl|xeval(ex|
|000002d0| 70 72 29 29 3b 0d 7d 0d | 0d 2f 2a 20 78 6c 78 65 |pr));.}.|./* xlxe|
|000002e0| 76 61 6c 20 2d 20 65 76 | 61 6c 75 61 74 65 20 61 |val - ev|aluate a|
|000002f0| 6e 20 78 6c 69 73 70 20 | 65 78 70 72 65 73 73 69 |n xlisp |expressi|
|00000300| 6f 6e 20 28 62 79 70 61 | 73 73 69 6e 67 20 2a 65 |on (bypa|ssing *e|
|00000310| 76 61 6c 68 6f 6f 6b 2a | 29 20 2a 2f 0d 4e 4f 44 |valhook*|) */.NOD|
|00000320| 45 20 2a 78 6c 78 65 76 | 61 6c 28 65 78 70 72 29 |E *xlxev|al(expr)|
|00000330| 0d 20 20 4e 4f 44 45 20 | 2a 65 78 70 72 3b 0d 7b |. NODE |*expr;.{|
|00000340| 0d 23 69 66 64 65 66 20 | 4d 45 47 41 4d 41 58 0d |.#ifdef |MEGAMAX.|
|00000350| 20 20 20 20 6d 61 63 69 | 64 6c 65 28 29 3b 0d 23 | maci|dle();.#|
|00000360| 65 6e 64 69 66 0d 0d 20 | 20 20 20 2f 2a 20 65 76 |endif.. | /* ev|
|00000370| 61 6c 75 61 74 65 20 6e | 69 6c 20 74 6f 20 69 74 |aluate n|il to it|
|00000380| 73 65 6c 66 20 2a 2f 0d | 20 20 20 20 69 66 20 28 |self */.| if (|
|00000390| 65 78 70 72 20 3d 3d 20 | 4e 49 4c 29 0d 09 72 65 |expr == |NIL)..re|
|000003a0| 74 75 72 6e 20 28 4e 49 | 4c 29 3b 0d 0d 20 20 20 |turn (NI|L);.. |
|000003b0| 20 2f 2a 20 61 64 64 20 | 74 72 61 63 65 20 65 6e | /* add |trace en|
|000003c0| 74 72 79 20 2a 2f 0d 20 | 20 20 20 78 6c 74 70 75 |try */. | xltpu|
|000003d0| 73 68 28 65 78 70 72 29 | 3b 0d 0d 20 20 20 20 2f |sh(expr)|;.. /|
|000003e0| 2a 20 63 68 65 63 6b 20 | 74 79 70 65 20 6f 66 20 |* check |type of |
|000003f0| 76 61 6c 75 65 20 2a 2f | 0d 20 20 20 20 69 66 20 |value */|. if |
|00000400| 28 63 6f 6e 73 70 28 65 | 78 70 72 29 29 0d 09 65 |(consp(e|xpr))..e|
|00000410| 78 70 72 20 3d 20 65 76 | 66 6f 72 6d 28 65 78 70 |xpr = ev|form(exp|
|00000420| 72 29 3b 0d 20 20 20 20 | 65 6c 73 65 20 69 66 20 |r);. |else if |
|00000430| 28 73 79 6d 62 6f 6c 70 | 28 65 78 70 72 29 29 0d |(symbolp|(expr)).|
|00000440| 09 65 78 70 72 20 3d 20 | 65 76 73 79 6d 28 65 78 |.expr = |evsym(ex|
|00000450| 70 72 29 3b 0d 0d 20 20 | 20 20 2f 2a 20 72 65 6d |pr);.. | /* rem|
|00000460| 6f 76 65 20 74 72 61 63 | 65 20 65 6e 74 72 79 20 |ove trac|e entry |
|00000470| 2a 2f 0d 20 20 20 20 78 | 6c 74 70 6f 70 28 29 3b |*/. x|ltpop();|
|00000480| 0d 0d 20 20 20 20 2f 2a | 20 72 65 74 75 72 6e 20 |.. /*| return |
|00000490| 74 68 65 20 76 61 6c 75 | 65 20 2a 2f 0d 20 20 20 |the valu|e */. |
|000004a0| 20 72 65 74 75 72 6e 20 | 28 65 78 70 72 29 3b 0d | return |(expr);.|
|000004b0| 7d 0d 0d 2f 2a 20 78 6c | 61 70 70 6c 79 20 2d 20 |}../* xl|apply - |
|000004c0| 61 70 70 6c 79 20 61 20 | 66 75 6e 63 74 69 6f 6e |apply a |function|
|000004d0| 20 74 6f 20 61 20 6c 69 | 73 74 20 6f 66 20 61 72 | to a li|st of ar|
|000004e0| 67 75 6d 65 6e 74 73 20 | 2a 2f 0d 4e 4f 44 45 20 |guments |*/.NODE |
|000004f0| 2a 78 6c 61 70 70 6c 79 | 28 66 75 6e 2c 61 72 67 |*xlapply|(fun,arg|
|00000500| 73 29 0d 20 20 4e 4f 44 | 45 20 2a 66 75 6e 2c 2a |s). NOD|E *fun,*|
|00000510| 61 72 67 73 3b 0d 7b 0d | 20 20 20 20 4e 4f 44 45 |args;.{.| NODE|
|00000520| 20 2a 76 61 6c 3b 0d 0d | 23 69 66 64 65 66 20 4d | *val;..|#ifdef M|
|00000530| 45 47 41 4d 41 58 0d 20 | 20 20 20 6d 61 63 69 64 |EGAMAX. | macid|
|00000540| 6c 65 28 29 3b 0d 23 65 | 6e 64 69 66 0d 0d 20 20 |le();.#e|ndif.. |
|00000550| 20 20 2f 2a 20 63 68 65 | 63 6b 20 66 6f 72 20 61 | /* che|ck for a|
|00000560| 20 6e 75 6c 6c 20 66 75 | 6e 63 74 69 6f 6e 20 2a | null fu|nction *|
|00000570| 2f 0d 20 20 20 20 69 66 | 20 28 66 75 6e 20 3d 3d |/. if| (fun ==|
|00000580| 20 4e 49 4c 29 0d 09 78 | 6c 66 61 69 6c 28 22 62 | NIL)..x|lfail("b|
|00000590| 61 64 20 66 75 6e 63 74 | 69 6f 6e 22 29 3b 0d 0d |ad funct|ion");..|
|000005a0| 20 20 20 20 2f 2a 20 65 | 76 61 6c 75 61 74 65 20 | /* e|valuate |
|000005b0| 74 68 65 20 66 75 6e 63 | 74 69 6f 6e 20 2a 2f 0d |the func|tion */.|
|000005c0| 20 20 20 20 69 66 20 28 | 73 75 62 72 70 28 66 75 | if (|subrp(fu|
|000005d0| 6e 29 29 0d 09 76 61 6c | 20 3d 20 28 2a 66 75 6e |n))..val| = (*fun|
|000005e0| 2d 3e 6e 5f 73 75 62 72 | 29 28 61 72 67 73 29 3b |->n_subr|)(args);|
|000005f0| 0d 20 20 20 20 65 6c 73 | 65 20 69 66 20 28 63 6f |. els|e if (co|
|00000600| 6e 73 70 28 66 75 6e 29 | 29 20 7b 0d 09 69 66 20 |nsp(fun)|) {..if |
|00000610| 28 63 61 72 28 66 75 6e | 29 20 21 3d 20 73 5f 6c |(car(fun|) != s_l|
|00000620| 61 6d 62 64 61 29 0d 09 | 20 20 20 20 78 6c 66 61 |ambda)..| xlfa|
|00000630| 69 6c 28 22 62 61 64 20 | 66 75 6e 63 74 69 6f 6e |il("bad |function|
|00000640| 20 74 79 70 65 22 29 3b | 0d 09 76 61 6c 20 3d 20 | type");|..val = |
|00000650| 65 76 66 75 6e 28 66 75 | 6e 2c 61 72 67 73 29 3b |evfun(fu|n,args);|
|00000660| 0d 20 20 20 20 7d 0d 20 | 20 20 20 65 6c 73 65 0d |. }. | else.|
|00000670| 09 78 6c 66 61 69 6c 28 | 22 62 61 64 20 66 75 6e |.xlfail(|"bad fun|
|00000680| 63 74 69 6f 6e 22 29 3b | 0d 0d 20 20 20 20 2f 2a |ction");|.. /*|
|00000690| 20 72 65 74 75 72 6e 20 | 74 68 65 20 72 65 73 75 | return |the resu|
|000006a0| 6c 74 20 76 61 6c 75 65 | 20 2a 2f 0d 20 20 20 20 |lt value| */. |
|000006b0| 72 65 74 75 72 6e 20 28 | 76 61 6c 29 3b 0d 7d 0d |return (|val);.}.|
|000006c0| 0d 2f 2a 20 65 76 66 6f | 72 6d 20 2d 20 65 76 61 |./* evfo|rm - eva|
|000006d0| 6c 75 61 74 65 20 61 20 | 66 6f 72 6d 20 2a 2f 0d |luate a |form */.|
|000006e0| 4c 4f 43 41 4c 20 4e 4f | 44 45 20 2a 65 76 66 6f |LOCAL NO|DE *evfo|
|000006f0| 72 6d 28 65 78 70 72 29 | 0d 20 20 4e 4f 44 45 20 |rm(expr)|. NODE |
|00000700| 2a 65 78 70 72 3b 0d 7b | 0d 20 20 20 20 4e 4f 44 |*expr;.{|. NOD|
|00000710| 45 20 2a 6f 6c 64 73 74 | 6b 2c 66 75 6e 2c 61 72 |E *oldst|k,fun,ar|
|00000720| 67 73 2c 2a 76 61 6c 2c | 2a 74 79 70 65 3b 0d 0d |gs,*val,|*type;..|
|00000730| 20 20 20 20 2f 2a 20 63 | 72 65 61 74 65 20 61 20 | /* c|reate a |
|00000740| 73 74 61 63 6b 20 66 72 | 61 6d 65 20 2a 2f 0d 20 |stack fr|ame */. |
|00000750| 20 20 20 6f 6c 64 73 74 | 6b 20 3d 20 78 6c 73 61 | oldst|k = xlsa|
|00000760| 76 65 28 26 66 75 6e 2c | 26 61 72 67 73 2c 4e 55 |ve(&fun,|&args,NU|
|00000770| 4c 4c 29 3b 0d 0d 20 20 | 20 20 2f 2a 20 67 65 74 |LL);.. | /* get|
|00000780| 20 74 68 65 20 66 75 6e | 63 74 69 6f 6e 20 61 6e | the fun|ction an|
|00000790| 64 20 74 68 65 20 61 72 | 67 75 6d 65 6e 74 20 6c |d the ar|gument l|
|000007a0| 69 73 74 20 2a 2f 0d 20 | 20 20 20 66 75 6e 2e 6e |ist */. | fun.n|
|000007b0| 5f 70 74 72 20 3d 20 63 | 61 72 28 65 78 70 72 29 |_ptr = c|ar(expr)|
|000007c0| 3b 0d 20 20 20 20 61 72 | 67 73 2e 6e 5f 70 74 72 |;. ar|gs.n_ptr|
|000007d0| 20 3d 20 63 64 72 28 65 | 78 70 72 29 3b 0d 0d 20 | = cdr(e|xpr);.. |
|000007e0| 20 20 20 2f 2a 20 65 76 | 61 6c 75 61 74 65 20 74 | /* ev|aluate t|
|000007f0| 68 65 20 66 69 72 73 74 | 20 65 78 70 72 65 73 73 |he first| express|
|00000800| 69 6f 6e 20 2a 2f 0d 20 | 20 20 20 69 66 20 28 28 |ion */. | if ((|
|00000810| 66 75 6e 2e 6e 5f 70 74 | 72 20 3d 20 78 6c 65 76 |fun.n_pt|r = xlev|
|00000820| 61 6c 28 66 75 6e 2e 6e | 5f 70 74 72 29 29 20 3d |al(fun.n|_ptr)) =|
|00000830| 3d 20 4e 49 4c 29 0d 09 | 78 6c 66 61 69 6c 28 22 |= NIL)..|xlfail("|
|00000840| 62 61 64 20 66 75 6e 63 | 74 69 6f 6e 22 29 3b 0d |bad func|tion");.|
|00000850| 0d 20 20 20 20 2f 2a 20 | 65 76 61 6c 75 61 74 65 |. /* |evaluate|
|00000860| 20 74 68 65 20 66 75 6e | 63 74 69 6f 6e 20 2a 2f | the fun|ction */|
|00000870| 0d 20 20 20 20 69 66 20 | 28 73 75 62 72 70 28 66 |. if |(subrp(f|
|00000880| 75 6e 2e 6e 5f 70 74 72 | 29 20 7c 7c 20 66 73 75 |un.n_ptr|) || fsu|
|00000890| 62 72 70 28 66 75 6e 2e | 6e 5f 70 74 72 29 29 20 |brp(fun.|n_ptr)) |
|000008a0| 7b 0d 09 69 66 20 28 73 | 75 62 72 70 28 66 75 6e |{..if (s|ubrp(fun|
|000008b0| 2e 6e 5f 70 74 72 29 29 | 0d 09 20 20 20 20 61 72 |.n_ptr))|.. ar|
|000008c0| 67 73 2e 6e 5f 70 74 72 | 20 3d 20 78 6c 65 76 6c |gs.n_ptr| = xlevl|
|000008d0| 69 73 74 28 61 72 67 73 | 2e 6e 5f 70 74 72 29 3b |ist(args|.n_ptr);|
|000008e0| 0d 09 76 61 6c 20 3d 20 | 28 2a 66 75 6e 2e 6e 5f |..val = |(*fun.n_|
|000008f0| 70 74 72 2d 3e 6e 5f 73 | 75 62 72 29 28 61 72 67 |ptr->n_s|ubr)(arg|
|00000900| 73 2e 6e 5f 70 74 72 29 | 3b 0d 20 20 20 20 7d 0d |s.n_ptr)|;. }.|
|00000910| 20 20 20 20 65 6c 73 65 | 20 69 66 20 28 63 6f 6e | else| if (con|
|00000920| 73 70 28 66 75 6e 2e 6e | 5f 70 74 72 29 29 20 7b |sp(fun.n|_ptr)) {|
|00000930| 0d 09 69 66 20 28 28 74 | 79 70 65 20 3d 20 63 61 |..if ((t|ype = ca|
|00000940| 72 28 66 75 6e 2e 6e 5f | 70 74 72 29 29 20 3d 3d |r(fun.n_|ptr)) ==|
|00000950| 20 73 5f 6c 61 6d 62 64 | 61 29 20 7b 0d 09 20 20 | s_lambd|a) {.. |
|00000960| 20 20 61 72 67 73 2e 6e | 5f 70 74 72 20 3d 20 78 | args.n|_ptr = x|
|00000970| 6c 65 76 6c 69 73 74 28 | 61 72 67 73 2e 6e 5f 70 |levlist(|args.n_p|
|00000980| 74 72 29 3b 0d 09 20 20 | 20 20 76 61 6c 20 3d 20 |tr);.. | val = |
|00000990| 65 76 66 75 6e 28 66 75 | 6e 2e 6e 5f 70 74 72 2c |evfun(fu|n.n_ptr,|
|000009a0| 61 72 67 73 2e 6e 5f 70 | 74 72 29 3b 0d 09 7d 0d |args.n_p|tr);..}.|
|000009b0| 09 65 6c 73 65 20 69 66 | 20 28 74 79 70 65 20 3d |.else if| (type =|
|000009c0| 3d 20 73 5f 6d 61 63 72 | 6f 29 20 7b 0d 09 20 20 |= s_macr|o) {.. |
|000009d0| 20 20 61 72 67 73 2e 6e | 5f 70 74 72 20 3d 20 65 | args.n|_ptr = e|
|000009e0| 76 66 75 6e 28 66 75 6e | 2e 6e 5f 70 74 72 2c 61 |vfun(fun|.n_ptr,a|
|000009f0| 72 67 73 2e 6e 5f 70 74 | 72 29 3b 0d 09 20 20 20 |rgs.n_pt|r);.. |
|00000a00| 20 76 61 6c 20 3d 20 78 | 6c 65 76 61 6c 28 61 72 | val = x|leval(ar|
|00000a10| 67 73 2e 6e 5f 70 74 72 | 29 3b 0d 09 7d 0d 09 65 |gs.n_ptr|);..}..e|
|00000a20| 6c 73 65 0d 09 20 20 20 | 20 78 6c 66 61 69 6c 28 |lse.. | xlfail(|
|00000a30| 22 62 61 64 20 66 75 6e | 63 74 69 6f 6e 20 74 79 |"bad fun|ction ty|
|00000a40| 70 65 22 29 3b 0d 20 20 | 20 20 7d 0d 20 20 20 20 |pe");. | }. |
|00000a50| 65 6c 73 65 20 69 66 20 | 28 6f 62 6a 65 63 74 70 |else if |(objectp|
|00000a60| 28 66 75 6e 2e 6e 5f 70 | 74 72 29 29 0d 09 76 61 |(fun.n_p|tr))..va|
|00000a70| 6c 20 3d 20 78 6c 73 65 | 6e 64 28 66 75 6e 2e 6e |l = xlse|nd(fun.n|
|00000a80| 5f 70 74 72 2c 61 72 67 | 73 2e 6e 5f 70 74 72 29 |_ptr,arg|s.n_ptr)|
|00000a90| 3b 0d 20 20 20 20 65 6c | 73 65 0d 09 78 6c 66 61 |;. el|se..xlfa|
|00000aa0| 69 6c 28 22 62 61 64 20 | 66 75 6e 63 74 69 6f 6e |il("bad |function|
|00000ab0| 22 29 3b 0d 0d 20 20 20 | 20 2f 2a 20 72 65 73 74 |");.. | /* rest|
|00000ac0| 6f 72 65 20 74 68 65 20 | 70 72 65 76 69 6f 75 73 |ore the |previous|
|00000ad0| 20 73 74 61 63 6b 20 66 | 72 61 6d 65 20 2a 2f 0d | stack f|rame */.|
|00000ae0| 20 20 20 20 78 6c 73 74 | 61 63 6b 20 3d 20 6f 6c | xlst|ack = ol|
|00000af0| 64 73 74 6b 3b 0d 0d 20 | 20 20 20 2f 2a 20 72 65 |dstk;.. | /* re|
|00000b00| 74 75 72 6e 20 74 68 65 | 20 72 65 73 75 6c 74 20 |turn the| result |
|00000b10| 76 61 6c 75 65 20 2a 2f | 0d 20 20 20 20 72 65 74 |value */|. ret|
|00000b20| 75 72 6e 20 28 76 61 6c | 29 3b 0d 7d 0d 0d 2f 2a |urn (val|);.}../*|
|00000b30| 20 65 76 61 6c 68 6f 6f | 6b 20 2d 20 63 61 6c 6c | evalhoo|k - call|
|00000b40| 20 74 68 65 20 65 76 61 | 6c 68 6f 6f 6b 20 66 75 | the eva|lhook fu|
|00000b50| 6e 63 74 69 6f 6e 20 2a | 2f 0d 4c 4f 43 41 4c 20 |nction *|/.LOCAL |
|00000b60| 4e 4f 44 45 20 2a 65 76 | 61 6c 68 6f 6f 6b 28 65 |NODE *ev|alhook(e|
|00000b70| 78 70 72 29 0d 20 20 4e | 4f 44 45 20 2a 65 78 70 |xpr). N|ODE *exp|
|00000b80| 72 3b 0d 7b 0d 20 20 20 | 20 4e 4f 44 45 20 2a 6f |r;.{. | NODE *o|
|00000b90| 6c 64 73 74 6b 2c 2a 6f | 6c 64 65 6e 76 2c 66 75 |ldstk,*o|ldenv,fu|
|00000ba0| 6e 2c 61 72 67 73 2c 2a | 76 61 6c 3b 0d 0d 20 20 |n,args,*|val;.. |
|00000bb0| 20 20 2f 2a 20 63 72 65 | 61 74 65 20 61 20 6e 65 | /* cre|ate a ne|
|00000bc0| 77 20 73 74 61 63 6b 20 | 66 72 61 6d 65 20 2a 2f |w stack |frame */|
|00000bd0| 0d 20 20 20 20 6f 6c 64 | 73 74 6b 20 3d 20 78 6c |. old|stk = xl|
|00000be0| 73 61 76 65 28 26 66 75 | 6e 2c 26 61 72 67 73 2c |save(&fu|n,&args,|
|00000bf0| 4e 55 4c 4c 29 3b 0d 0d | 20 20 20 20 2f 2a 20 67 |NULL);..| /* g|
|00000c00| 65 74 20 74 68 65 20 68 | 6f 6f 6b 20 66 75 6e 63 |et the h|ook func|
|00000c10| 74 69 6f 6e 20 2a 2f 0d | 20 20 20 20 66 75 6e 2e |tion */.| fun.|
|00000c20| 6e 5f 70 74 72 20 3d 20 | 73 5f 65 76 61 6c 68 6f |n_ptr = |s_evalho|
|00000c30| 6f 6b 2d 3e 6e 5f 73 79 | 6d 76 61 6c 75 65 3b 0d |ok->n_sy|mvalue;.|
|00000c40| 0d 20 20 20 20 2f 2a 20 | 6d 61 6b 65 20 61 6e 20 |. /* |make an |
|00000c50| 61 72 67 75 6d 65 6e 74 | 20 6c 69 73 74 20 2a 2f |argument| list */|
|00000c60| 0d 20 20 20 20 61 72 67 | 73 2e 6e 5f 70 74 72 20 |. arg|s.n_ptr |
|00000c70| 3d 20 6e 65 77 6e 6f 64 | 65 28 4c 49 53 54 29 3b |= newnod|e(LIST);|
|00000c80| 0d 20 20 20 20 72 70 6c | 61 63 61 28 61 72 67 73 |. rpl|aca(args|
|00000c90| 2e 6e 5f 70 74 72 2c 65 | 78 70 72 29 3b 0d 0d 20 |.n_ptr,e|xpr);.. |
|00000ca0| 20 20 20 2f 2a 20 72 65 | 62 69 6e 64 20 74 68 65 | /* re|bind the|
|00000cb0| 20 68 6f 6f 6b 20 66 75 | 6e 63 74 69 6f 6e 73 20 | hook fu|nctions |
|00000cc0| 74 6f 20 6e 69 6c 20 2a | 2f 0d 20 20 20 20 6f 6c |to nil *|/. ol|
|00000cd0| 64 65 6e 76 20 3d 20 78 | 6c 65 6e 76 3b 0d 20 20 |denv = x|lenv;. |
|00000ce0| 20 20 78 6c 73 62 69 6e | 64 28 73 5f 65 76 61 6c | xlsbin|d(s_eval|
|00000cf0| 68 6f 6f 6b 2c 4e 49 4c | 29 3b 0d 20 20 20 20 78 |hook,NIL|);. x|
|00000d00| 6c 73 62 69 6e 64 28 73 | 5f 61 70 70 6c 79 68 6f |lsbind(s|_applyho|
|00000d10| 6f 6b 2c 4e 49 4c 29 3b | 0d 0d 20 20 20 20 2f 2a |ok,NIL);|.. /*|
|00000d20| 20 63 61 6c 6c 20 74 68 | 65 20 68 6f 6f 6b 20 66 | call th|e hook f|
|00000d30| 75 6e 63 74 69 6f 6e 20 | 2a 2f 0d 20 20 20 20 76 |unction |*/. v|
|00000d40| 61 6c 20 3d 20 78 6c 61 | 70 70 6c 79 28 66 75 6e |al = xla|pply(fun|
|00000d50| 2e 6e 5f 70 74 72 2c 61 | 72 67 73 2e 6e 5f 70 74 |.n_ptr,a|rgs.n_pt|
|00000d60| 72 29 3b 0d 0d 20 20 20 | 20 2f 2a 20 75 6e 62 69 |r);.. | /* unbi|
|00000d70| 6e 64 20 74 68 65 20 73 | 79 6d 62 6f 6c 73 20 2a |nd the s|ymbols *|
|00000d80| 2f 0d 20 20 20 20 78 6c | 75 6e 62 69 6e 64 28 6f |/. xl|unbind(o|
|00000d90| 6c 64 65 6e 76 29 3b 0d | 0d 20 20 20 20 2f 2a 20 |ldenv);.|. /* |
|00000da0| 72 65 73 74 6f 72 65 20 | 74 68 65 20 70 72 65 76 |restore |the prev|
|00000db0| 69 6f 75 73 20 73 74 61 | 63 6b 20 66 72 61 6d 65 |ious sta|ck frame|
|00000dc0| 20 2a 2f 0d 20 20 20 20 | 78 6c 73 74 61 63 6b 20 | */. |xlstack |
|00000dd0| 3d 20 6f 6c 64 73 74 6b | 3b 0d 0d 20 20 20 20 2f |= oldstk|;.. /|
|00000de0| 2a 20 72 65 74 75 72 6e | 20 74 68 65 20 76 61 6c |* return| the val|
|00000df0| 75 65 20 2a 2f 0d 20 20 | 20 20 72 65 74 75 72 6e |ue */. | return|
|00000e00| 20 28 76 61 6c 29 3b 0d | 7d 0d 0d 2f 2a 20 78 6c | (val);.|}../* xl|
|00000e10| 65 76 6c 69 73 74 20 2d | 20 65 76 61 6c 75 61 74 |evlist -| evaluat|
|00000e20| 65 20 61 20 6c 69 73 74 | 20 6f 66 20 61 72 67 75 |e a list| of argu|
|00000e30| 6d 65 6e 74 73 20 2a 2f | 0d 4e 4f 44 45 20 2a 78 |ments */|.NODE *x|
|00000e40| 6c 65 76 6c 69 73 74 28 | 61 72 67 73 29 0d 20 20 |levlist(|args). |
|00000e50| 4e 4f 44 45 20 2a 61 72 | 67 73 3b 0d 7b 0d 20 20 |NODE *ar|gs;.{. |
|00000e60| 20 20 4e 4f 44 45 20 2a | 6f 6c 64 73 74 6b 2c 73 | NODE *|oldstk,s|
|00000e70| 72 63 2c 64 73 74 2c 2a | 6e 65 77 2c 2a 6c 61 73 |rc,dst,*|new,*las|
|00000e80| 74 2c 2a 76 61 6c 3b 0d | 0d 20 20 20 20 2f 2a 20 |t,*val;.|. /* |
|00000e90| 63 72 65 61 74 65 20 61 | 20 73 74 61 63 6b 20 66 |create a| stack f|
|00000ea0| 72 61 6d 65 20 2a 2f 0d | 20 20 20 20 6f 6c 64 73 |rame */.| olds|
|00000eb0| 74 6b 20 3d 20 78 6c 73 | 61 76 65 28 26 73 72 63 |tk = xls|ave(&src|
|00000ec0| 2c 26 64 73 74 2c 4e 55 | 4c 4c 29 3b 0d 0d 20 20 |,&dst,NU|LL);.. |
|00000ed0| 20 20 2f 2a 20 69 6e 69 | 74 69 61 6c 69 7a 65 20 | /* ini|tialize |
|00000ee0| 2a 2f 0d 20 20 20 20 73 | 72 63 2e 6e 5f 70 74 72 |*/. s|rc.n_ptr|
|00000ef0| 20 3d 20 61 72 67 73 3b | 0d 0d 20 20 20 20 2f 2a | = args;|.. /*|
|00000f00| 20 65 76 61 6c 75 61 74 | 65 20 65 61 63 68 20 61 | evaluat|e each a|
|00000f10| 72 67 75 6d 65 6e 74 20 | 2a 2f 0d 20 20 20 20 66 |rgument |*/. f|
|00000f20| 6f 72 20 28 76 61 6c 20 | 3d 20 4e 49 4c 3b 20 73 |or (val |= NIL; s|
|00000f30| 72 63 2e 6e 5f 70 74 72 | 3b 20 73 72 63 2e 6e 5f |rc.n_ptr|; src.n_|
|00000f40| 70 74 72 20 3d 20 63 64 | 72 28 73 72 63 2e 6e 5f |ptr = cd|r(src.n_|
|00000f50| 70 74 72 29 29 20 7b 0d | 0d 09 2f 2a 20 63 68 65 |ptr)) {.|../* che|
|00000f60| 63 6b 20 74 68 69 73 20 | 65 6e 74 72 79 20 2a 2f |ck this |entry */|
|00000f70| 0d 09 69 66 20 28 21 63 | 6f 6e 73 70 28 73 72 63 |..if (!c|onsp(src|
|00000f80| 2e 6e 5f 70 74 72 29 29 | 0d 09 20 20 20 20 78 6c |.n_ptr))|.. xl|
|00000f90| 66 61 69 6c 28 22 62 61 | 64 20 61 72 67 75 6d 65 |fail("ba|d argume|
|00000fa0| 6e 74 20 6c 69 73 74 22 | 29 3b 0d 0d 09 2f 2a 20 |nt list"|);.../* |
|00000fb0| 61 6c 6c 6f 63 61 74 65 | 20 61 20 6e 65 77 20 6c |allocate| a new l|
|00000fc0| 69 73 74 20 65 6e 74 72 | 79 20 2a 2f 0d 09 6e 65 |ist entr|y */..ne|
|00000fd0| 77 20 3d 20 6e 65 77 6e | 6f 64 65 28 4c 49 53 54 |w = newn|ode(LIST|
|00000fe0| 29 3b 0d 09 69 66 20 28 | 76 61 6c 29 0d 09 20 20 |);..if (|val).. |
|00000ff0| 20 20 72 70 6c 61 63 64 | 28 6c 61 73 74 2c 6e 65 | rplacd|(last,ne|
|00001000| 77 29 3b 0d 09 65 6c 73 | 65 0d 09 20 20 20 20 76 |w);..els|e.. v|
|00001010| 61 6c 20 3d 20 64 73 74 | 2e 6e 5f 70 74 72 20 3d |al = dst|.n_ptr =|
|00001020| 20 6e 65 77 3b 0d 09 72 | 70 6c 61 63 61 28 6e 65 | new;..r|placa(ne|
|00001030| 77 2c 78 6c 65 76 61 6c | 28 63 61 72 28 73 72 63 |w,xleval|(car(src|
|00001040| 2e 6e 5f 70 74 72 29 29 | 29 3b 0d 09 6c 61 73 74 |.n_ptr))|);..last|
|00001050| 20 3d 20 6e 65 77 3b 0d | 20 20 20 20 7d 0d 0d 20 | = new;.| }.. |
|00001060| 20 20 20 2f 2a 20 72 65 | 73 74 6f 72 65 20 74 68 | /* re|store th|
|00001070| 65 20 70 72 65 76 69 6f | 75 73 20 73 74 61 63 6b |e previo|us stack|
|00001080| 20 66 72 61 6d 65 20 2a | 2f 0d 20 20 20 20 78 6c | frame *|/. xl|
|00001090| 73 74 61 63 6b 20 3d 20 | 6f 6c 64 73 74 6b 3b 0d |stack = |oldstk;.|
|000010a0| 0d 20 20 20 20 2f 2a 20 | 72 65 74 75 72 6e 20 74 |. /* |return t|
|000010b0| 68 65 20 6e 65 77 20 6c | 69 73 74 20 2a 2f 0d 20 |he new l|ist */. |
|000010c0| 20 20 20 72 65 74 75 72 | 6e 20 28 76 61 6c 29 3b | retur|n (val);|
|000010d0| 0d 7d 0d 0d 2f 2a 20 65 | 76 73 79 6d 20 2d 20 65 |.}../* e|vsym - e|
|000010e0| 76 61 6c 75 61 74 65 20 | 61 20 73 79 6d 62 6f 6c |valuate |a symbol|
|000010f0| 20 2a 2f 0d 4c 4f 43 41 | 4c 20 4e 4f 44 45 20 2a | */.LOCA|L NODE *|
|00001100| 65 76 73 79 6d 28 73 79 | 6d 29 0d 20 20 4e 4f 44 |evsym(sy|m). NOD|
|00001110| 45 20 2a 73 79 6d 3b 0d | 7b 0d 20 20 20 20 4e 4f |E *sym;.|{. NO|
|00001120| 44 45 20 2a 70 3b 0d 0d | 20 20 20 20 2f 2a 20 63 |DE *p;..| /* c|
|00001130| 68 65 63 6b 20 66 6f 72 | 20 61 20 72 65 66 65 72 |heck for| a refer|
|00001140| 65 6e 63 65 20 74 6f 20 | 61 6e 20 69 6e 73 74 61 |ence to |an insta|
|00001150| 6e 63 65 20 76 61 72 69 | 61 62 6c 65 20 2a 2f 0d |nce vari|able */.|
|00001160| 20 20 20 20 69 66 20 28 | 28 70 20 3d 20 78 6c 6f | if (|(p = xlo|
|00001170| 62 73 79 6d 28 73 79 6d | 29 29 20 21 3d 20 4e 49 |bsym(sym|)) != NI|
|00001180| 4c 29 0d 09 72 65 74 75 | 72 6e 20 28 63 61 72 28 |L)..retu|rn (car(|
|00001190| 70 29 29 3b 0d 0d 20 20 | 20 20 2f 2a 20 67 65 74 |p));.. | /* get|
|000011a0| 20 74 68 65 20 76 61 6c | 75 65 20 6f 66 20 74 68 | the val|ue of th|
|000011b0| 65 20 76 61 72 69 61 62 | 6c 65 20 2a 2f 0d 20 20 |e variab|le */. |
|000011c0| 20 20 77 68 69 6c 65 20 | 28 28 70 20 3d 20 73 79 | while |((p = sy|
|000011d0| 6d 2d 3e 6e 5f 73 79 6d | 76 61 6c 75 65 29 20 3d |m->n_sym|value) =|
|000011e0| 3d 20 73 5f 75 6e 62 6f | 75 6e 64 29 0d 09 78 6c |= s_unbo|und)..xl|
|000011f0| 75 6e 62 6f 75 6e 64 28 | 73 79 6d 29 3b 0d 0d 20 |unbound(|sym);.. |
|00001200| 20 20 20 2f 2a 20 72 65 | 74 75 72 6e 20 74 68 65 | /* re|turn the|
|00001210| 20 76 61 6c 75 65 20 2a | 2f 0d 20 20 20 20 72 65 | value *|/. re|
|00001220| 74 75 72 6e 20 28 70 29 | 3b 0d 7d 0d 0d 2f 2a 20 |turn (p)|;.}../* |
|00001230| 78 6c 75 6e 62 6f 75 6e | 64 20 2d 20 73 69 67 6e |xlunboun|d - sign|
|00001240| 61 6c 20 61 6e 20 75 6e | 62 6f 75 6e 64 20 76 61 |al an un|bound va|
|00001250| 72 69 61 62 6c 65 20 65 | 72 72 6f 72 20 2a 2f 0d |riable e|rror */.|
|00001260| 78 6c 75 6e 62 6f 75 6e | 64 28 73 79 6d 29 0d 20 |xlunboun|d(sym). |
|00001270| 20 4e 4f 44 45 20 2a 73 | 79 6d 3b 0d 7b 0d 20 20 | NODE *s|ym;.{. |
|00001280| 20 20 78 6c 63 65 72 72 | 6f 72 28 22 74 72 79 20 | xlcerr|or("try |
|00001290| 65 76 61 6c 75 61 74 69 | 6e 67 20 73 79 6d 62 6f |evaluati|ng symbo|
|000012a0| 6c 20 61 67 61 69 6e 22 | 2c 22 75 6e 62 6f 75 6e |l again"|,"unboun|
|000012b0| 64 20 76 61 72 69 61 62 | 6c 65 22 2c 73 79 6d 29 |d variab|le",sym)|
|000012c0| 3b 0d 7d 0d 0d 2f 2a 20 | 65 76 66 75 6e 20 2d 20 |;.}../* |evfun - |
|000012d0| 65 76 61 6c 75 61 74 65 | 20 61 20 66 75 6e 63 74 |evaluate| a funct|
|000012e0| 69 6f 6e 20 2a 2f 0d 4c | 4f 43 41 4c 20 4e 4f 44 |ion */.L|OCAL NOD|
|000012f0| 45 20 2a 65 76 66 75 6e | 28 66 75 6e 2c 61 72 67 |E *evfun|(fun,arg|
|00001300| 73 29 0d 20 20 4e 4f 44 | 45 20 2a 66 75 6e 2c 2a |s). NOD|E *fun,*|
|00001310| 61 72 67 73 3b 0d 7b 0d | 20 20 20 20 4e 4f 44 45 |args;.{.| NODE|
|00001320| 20 2a 6f 6c 64 73 74 6b | 2c 2a 6f 6c 64 65 6e 76 | *oldstk|,*oldenv|
|00001330| 2c 2a 6f 6c 64 6e 65 77 | 65 6e 76 2c 63 70 74 72 |,*oldnew|env,cptr|
|00001340| 2c 2a 66 61 72 67 73 2c | 2a 76 61 6c 3b 0d 0d 20 |,*fargs,|*val;.. |
|00001350| 20 20 20 2f 2a 20 63 72 | 65 61 74 65 20 61 20 73 | /* cr|eate a s|
|00001360| 74 61 63 6b 20 66 72 61 | 6d 65 20 2a 2f 0d 20 20 |tack fra|me */. |
|00001370| 20 20 6f 6c 64 73 74 6b | 20 3d 20 78 6c 73 61 76 | oldstk| = xlsav|
|00001380| 65 28 26 63 70 74 72 2c | 4e 55 4c 4c 29 3b 0d 0d |e(&cptr,|NULL);..|
|00001390| 20 20 20 20 2f 2a 20 73 | 6b 69 70 20 74 68 65 20 | /* s|kip the |
|000013a0| 66 75 6e 63 74 69 6f 6e | 20 74 79 70 65 20 2a 2f |function| type */|
|000013b0| 0d 20 20 20 20 69 66 20 | 28 28 66 75 6e 20 3d 20 |. if |((fun = |
|000013c0| 63 64 72 28 66 75 6e 29 | 29 20 3d 3d 20 4e 49 4c |cdr(fun)|) == NIL|
|000013d0| 20 7c 7c 20 21 63 6f 6e | 73 70 28 66 75 6e 29 29 | || !con|sp(fun))|
|000013e0| 0d 09 78 6c 66 61 69 6c | 28 22 62 61 64 20 66 75 |..xlfail|("bad fu|
|000013f0| 6e 63 74 69 6f 6e 20 64 | 65 66 69 6e 69 74 69 6f |nction d|efinitio|
|00001400| 6e 22 29 3b 0d 0d 20 20 | 20 20 2f 2a 20 67 65 74 |n");.. | /* get|
|00001410| 20 74 68 65 20 66 6f 72 | 6d 61 6c 20 61 72 67 75 | the for|mal argu|
|00001420| 6d 65 6e 74 20 6c 69 73 | 74 20 2a 2f 0d 20 20 20 |ment lis|t */. |
|00001430| 20 69 66 20 28 28 66 61 | 72 67 73 20 3d 20 63 61 | if ((fa|rgs = ca|
|00001440| 72 28 66 75 6e 29 29 20 | 26 26 20 21 63 6f 6e 73 |r(fun)) |&& !cons|
|00001450| 70 28 66 61 72 67 73 29 | 29 0d 09 78 6c 66 61 69 |p(fargs)|)..xlfai|
|00001460| 6c 28 22 62 61 64 20 66 | 6f 72 6d 61 6c 20 61 72 |l("bad f|ormal ar|
|00001470| 67 75 6d 65 6e 74 20 6c | 69 73 74 22 29 3b 0d 0d |gument l|ist");..|
|00001480| 20 20 20 20 2f 2a 20 62 | 69 6e 64 20 74 68 65 20 | /* b|ind the |
|00001490| 66 6f 72 6d 61 6c 20 70 | 61 72 61 6d 65 74 65 72 |formal p|arameter|
|000014a0| 73 20 2a 2f 0d 20 20 20 | 20 6f 6c 64 6e 65 77 65 |s */. | oldnewe|
|000014b0| 6e 76 20 3d 20 78 6c 6e | 65 77 65 6e 76 3b 20 6f |nv = xln|ewenv; o|
|000014c0| 6c 64 65 6e 76 20 3d 20 | 78 6c 6e 65 77 65 6e 76 |ldenv = |xlnewenv|
|000014d0| 20 3d 20 78 6c 65 6e 76 | 3b 0d 20 20 20 20 78 6c | = xlenv|;. xl|
|000014e0| 61 62 69 6e 64 28 66 61 | 72 67 73 2c 61 72 67 73 |abind(fa|rgs,args|
|000014f0| 29 3b 0d 20 20 20 20 78 | 6c 66 69 78 62 69 6e 64 |);. x|lfixbind|
|00001500| 69 6e 67 73 28 29 3b 0d | 0d 20 20 20 20 2f 2a 20 |ings();.|. /* |
|00001510| 65 78 65 63 75 74 65 20 | 74 68 65 20 63 6f 64 65 |execute |the code|
|00001520| 20 2a 2f 0d 20 20 20 20 | 66 6f 72 20 28 63 70 74 | */. |for (cpt|
|00001530| 72 2e 6e 5f 70 74 72 20 | 3d 20 63 64 72 28 66 75 |r.n_ptr |= cdr(fu|
|00001540| 6e 29 3b 20 63 70 74 72 | 2e 6e 5f 70 74 72 20 21 |n); cptr|.n_ptr !|
|00001550| 3d 20 4e 49 4c 3b 20 29 | 0d 09 76 61 6c 20 3d 20 |= NIL; )|..val = |
|00001560| 78 6c 65 76 61 72 67 28 | 26 63 70 74 72 2e 6e 5f |xlevarg(|&cptr.n_|
|00001570| 70 74 72 29 3b 0d 0d 20 | 20 20 20 2f 2a 20 72 65 |ptr);.. | /* re|
|00001580| 73 74 6f 72 65 20 74 68 | 65 20 65 6e 76 69 72 6f |store th|e enviro|
|00001590| 6e 6d 65 6e 74 20 2a 2f | 0d 20 20 20 20 78 6c 75 |nment */|. xlu|
|000015a0| 6e 62 69 6e 64 28 6f 6c | 64 65 6e 76 29 3b 20 78 |nbind(ol|denv); x|
|000015b0| 6c 6e 65 77 65 6e 76 20 | 3d 20 6f 6c 64 6e 65 77 |lnewenv |= oldnew|
|000015c0| 65 6e 76 3b 0d 0d 20 20 | 20 20 2f 2a 20 72 65 73 |env;.. | /* res|
|000015d0| 74 6f 72 65 20 74 68 65 | 20 70 72 65 76 69 6f 75 |tore the| previou|
|000015e0| 73 20 73 74 61 63 6b 20 | 66 72 61 6d 65 20 2a 2f |s stack |frame */|
|000015f0| 0d 20 20 20 20 78 6c 73 | 74 61 63 6b 20 3d 20 6f |. xls|tack = o|
|00001600| 6c 64 73 74 6b 3b 0d 0d | 20 20 20 20 2f 2a 20 72 |ldstk;..| /* r|
|00001610| 65 74 75 72 6e 20 74 68 | 65 20 72 65 73 75 6c 74 |eturn th|e result|
|00001620| 20 76 61 6c 75 65 20 2a | 2f 0d 20 20 20 20 72 65 | value *|/. re|
|00001630| 74 75 72 6e 20 28 76 61 | 6c 29 3b 0d 7d 0d 0d 2f |turn (va|l);.}../|
|00001640| 2a 20 78 6c 61 62 69 6e | 64 20 2d 20 62 69 6e 64 |* xlabin|d - bind|
|00001650| 20 74 68 65 20 61 72 67 | 75 6d 65 6e 74 73 20 66 | the arg|uments f|
|00001660| 6f 72 20 61 20 66 75 6e | 63 74 69 6f 6e 20 2a 2f |or a fun|ction */|
|00001670| 0d 78 6c 61 62 69 6e 64 | 28 66 61 72 67 73 2c 61 |.xlabind|(fargs,a|
|00001680| 61 72 67 73 29 0d 20 20 | 4e 4f 44 45 20 2a 66 61 |args). |NODE *fa|
|00001690| 72 67 73 2c 2a 61 61 72 | 67 73 3b 0d 7b 0d 20 20 |rgs,*aar|gs;.{. |
|000016a0| 20 20 4e 4f 44 45 20 2a | 61 72 67 3b 0d 0d 20 20 | NODE *|arg;.. |
|000016b0| 20 20 2f 2a 20 65 76 61 | 6c 75 61 74 65 20 61 6e | /* eva|luate an|
|000016c0| 64 20 62 69 6e 64 20 65 | 61 63 68 20 72 65 71 75 |d bind e|ach requ|
|000016d0| 69 72 65 64 20 61 72 67 | 75 6d 65 6e 74 20 2a 2f |ired arg|ument */|
|000016e0| 0d 20 20 20 20 77 68 69 | 6c 65 20 28 63 6f 6e 73 |. whi|le (cons|
|000016f0| 70 28 66 61 72 67 73 29 | 20 26 26 20 21 69 73 6b |p(fargs)| && !isk|
|00001700| 65 79 77 6f 72 64 28 61 | 72 67 20 3d 20 63 61 72 |eyword(a|rg = car|
|00001710| 28 66 61 72 67 73 29 29 | 20 26 26 20 63 6f 6e 73 |(fargs))| && cons|
|00001720| 70 28 61 61 72 67 73 29 | 29 20 7b 0d 0d 09 2f 2a |p(aargs)|) {.../*|
|00001730| 20 62 69 6e 64 20 74 68 | 65 20 66 6f 72 6d 61 6c | bind th|e formal|
|00001740| 20 76 61 72 69 61 62 6c | 65 20 74 6f 20 74 68 65 | variabl|e to the|
|00001750| 20 61 72 67 75 6d 65 6e | 74 20 76 61 6c 75 65 20 | argumen|t value |
|00001760| 2a 2f 0d 09 78 6c 62 69 | 6e 64 28 61 72 67 2c 63 |*/..xlbi|nd(arg,c|
|00001770| 61 72 28 61 61 72 67 73 | 29 29 3b 0d 0d 09 2f 2a |ar(aargs|));.../*|
|00001780| 20 6d 6f 76 65 20 74 68 | 65 20 61 72 67 75 6d 65 | move th|e argume|
|00001790| 6e 74 20 6c 69 73 74 20 | 70 6f 69 6e 74 65 72 73 |nt list |pointers|
|000017a0| 20 61 68 65 61 64 20 2a | 2f 0d 09 66 61 72 67 73 | ahead *|/..fargs|
|000017b0| 20 3d 20 63 64 72 28 66 | 61 72 67 73 29 3b 0d 09 | = cdr(f|args);..|
|000017c0| 61 61 72 67 73 20 3d 20 | 63 64 72 28 61 61 72 67 |aargs = |cdr(aarg|
|000017d0| 73 29 3b 0d 20 20 20 20 | 7d 0d 0d 20 20 20 20 2f |s);. |}.. /|
|000017e0| 2a 20 63 68 65 63 6b 20 | 66 6f 72 20 74 68 65 20 |* check |for the |
|000017f0| 27 26 6f 70 74 69 6f 6e | 61 6c 27 20 6b 65 79 77 |'&option|al' keyw|
|00001800| 6f 72 64 20 2a 2f 0d 20 | 20 20 20 69 66 20 28 63 |ord */. | if (c|
|00001810| 6f 6e 73 70 28 66 61 72 | 67 73 29 20 26 26 20 63 |onsp(far|gs) && c|
|00001820| 61 72 28 66 61 72 67 73 | 29 20 3d 3d 20 6b 5f 6f |ar(fargs|) == k_o|
|00001830| 70 74 69 6f 6e 61 6c 29 | 20 7b 0d 09 66 61 72 67 |ptional)| {..farg|
|00001840| 73 20 3d 20 63 64 72 28 | 66 61 72 67 73 29 3b 0d |s = cdr(|fargs);.|
|00001850| 0d 09 2f 2a 20 62 69 6e | 64 20 74 68 65 20 61 72 |../* bin|d the ar|
|00001860| 67 75 6d 65 6e 74 73 20 | 74 68 61 74 20 77 65 72 |guments |that wer|
|00001870| 65 20 73 75 70 70 6c 69 | 65 64 20 2a 2f 0d 09 77 |e suppli|ed */..w|
|00001880| 68 69 6c 65 20 28 63 6f | 6e 73 70 28 66 61 72 67 |hile (co|nsp(farg|
|00001890| 73 29 20 26 26 20 21 69 | 73 6b 65 79 77 6f 72 64 |s) && !i|skeyword|
|000018a0| 28 61 72 67 20 3d 20 63 | 61 72 28 66 61 72 67 73 |(arg = c|ar(fargs|
|000018b0| 29 29 20 26 26 20 63 6f | 6e 73 70 28 61 61 72 67 |)) && co|nsp(aarg|
|000018c0| 73 29 29 20 7b 0d 0d 09 | 20 20 20 20 2f 2a 20 62 |s)) {...| /* b|
|000018d0| 69 6e 64 20 74 68 65 20 | 66 6f 72 6d 61 6c 20 76 |ind the |formal v|
|000018e0| 61 72 69 61 62 6c 65 20 | 74 6f 20 74 68 65 20 61 |ariable |to the a|
|000018f0| 72 67 75 6d 65 6e 74 20 | 76 61 6c 75 65 20 2a 2f |rgument |value */|
|00001900| 0d 09 20 20 20 20 78 6c | 62 69 6e 64 28 61 72 67 |.. xl|bind(arg|
|00001910| 2c 63 61 72 28 61 61 72 | 67 73 29 29 3b 0d 0d 09 |,car(aar|gs));...|
|00001920| 20 20 20 20 2f 2a 20 6d | 6f 76 65 20 74 68 65 20 | /* m|ove the |
|00001930| 61 72 67 75 6d 65 6e 74 | 20 6c 69 73 74 20 70 6f |argument| list po|
|00001940| 69 6e 74 65 72 73 20 61 | 68 65 61 64 20 2a 2f 0d |inters a|head */.|
|00001950| 09 20 20 20 20 66 61 72 | 67 73 20 3d 20 63 64 72 |. far|gs = cdr|
|00001960| 28 66 61 72 67 73 29 3b | 0d 09 20 20 20 20 61 61 |(fargs);|.. aa|
|00001970| 72 67 73 20 3d 20 63 64 | 72 28 61 61 72 67 73 29 |rgs = cd|r(aargs)|
|00001980| 3b 0d 09 7d 0d 0d 09 2f | 2a 20 62 69 6e 64 20 74 |;..}.../|* bind t|
|00001990| 68 65 20 72 65 73 74 20 | 74 6f 20 6e 69 6c 20 2a |he rest |to nil *|
|000019a0| 2f 0d 09 77 68 69 6c 65 | 20 28 63 6f 6e 73 70 28 |/..while| (consp(|
|000019b0| 66 61 72 67 73 29 20 26 | 26 20 21 69 73 6b 65 79 |fargs) &|& !iskey|
|000019c0| 77 6f 72 64 28 61 72 67 | 20 3d 20 63 61 72 28 66 |word(arg| = car(f|
|000019d0| 61 72 67 73 29 29 29 20 | 7b 0d 0d 09 20 20 20 20 |args))) |{... |
|000019e0| 2f 2a 20 62 69 6e 64 20 | 74 68 65 20 66 6f 72 6d |/* bind |the form|
|000019f0| 61 6c 20 76 61 72 69 61 | 62 6c 65 20 74 6f 20 6e |al varia|ble to n|
|00001a00| 69 6c 20 2a 2f 0d 09 20 | 20 20 20 78 6c 62 69 6e |il */.. | xlbin|
|00001a10| 64 28 61 72 67 2c 4e 49 | 4c 29 3b 0d 0d 09 20 20 |d(arg,NI|L);... |
|00001a20| 20 20 2f 2a 20 6d 6f 76 | 65 20 74 68 65 20 61 72 | /* mov|e the ar|
|00001a30| 67 75 6d 65 6e 74 20 6c | 69 73 74 20 70 6f 69 6e |gument l|ist poin|
|00001a40| 74 65 72 20 61 68 65 61 | 64 20 2a 2f 0d 09 20 20 |ter ahea|d */.. |
|00001a50| 20 20 66 61 72 67 73 20 | 3d 20 63 64 72 28 66 61 | fargs |= cdr(fa|
|00001a60| 72 67 73 29 3b 0d 09 7d | 0d 20 20 20 20 7d 0d 0d |rgs);..}|. }..|
|00001a70| 20 20 20 20 2f 2a 20 63 | 68 65 63 6b 20 66 6f 72 | /* c|heck for|
|00001a80| 20 74 68 65 20 27 26 72 | 65 73 74 27 20 6b 65 79 | the '&r|est' key|
|00001a90| 77 6f 72 64 20 2a 2f 0d | 20 20 20 20 69 66 20 28 |word */.| if (|
|00001aa0| 63 6f 6e 73 70 28 66 61 | 72 67 73 29 20 26 26 20 |consp(fa|rgs) && |
|00001ab0| 63 61 72 28 66 61 72 67 | 73 29 20 3d 3d 20 6b 5f |car(farg|s) == k_|
|00001ac0| 72 65 73 74 29 20 7b 0d | 09 66 61 72 67 73 20 3d |rest) {.|.fargs =|
|00001ad0| 20 63 64 72 28 66 61 72 | 67 73 29 3b 0d 09 69 66 | cdr(far|gs);..if|
|00001ae0| 20 28 63 6f 6e 73 70 28 | 66 61 72 67 73 29 20 26 | (consp(|fargs) &|
|00001af0| 26 20 28 61 72 67 20 3d | 20 63 61 72 28 66 61 72 |& (arg =| car(far|
|00001b00| 67 73 29 29 20 26 26 20 | 21 69 73 6b 65 79 77 6f |gs)) && |!iskeywo|
|00001b10| 72 64 28 61 72 67 29 29 | 0d 09 20 20 20 20 78 6c |rd(arg))|.. xl|
|00001b20| 62 69 6e 64 28 61 72 67 | 2c 61 61 72 67 73 29 3b |bind(arg|,aargs);|
|00001b30| 0d 09 65 6c 73 65 0d 09 | 20 20 20 20 78 6c 66 61 |..else..| xlfa|
|00001b40| 69 6c 28 22 73 79 6d 62 | 6f 6c 20 6d 69 73 73 69 |il("symb|ol missi|
|00001b50| 6e 67 20 61 66 74 65 72 | 20 26 72 65 73 74 22 29 |ng after| &rest")|
|00001b60| 3b 0d 09 66 61 72 67 73 | 20 3d 20 63 64 72 28 66 |;..fargs| = cdr(f|
|00001b70| 61 72 67 73 29 3b 0d 09 | 61 61 72 67 73 20 3d 20 |args);..|aargs = |
|00001b80| 4e 49 4c 3b 0d 20 20 20 | 20 7d 0d 0d 20 20 20 20 |NIL;. | }.. |
|00001b90| 2f 2a 20 63 68 65 63 6b | 20 66 6f 72 20 74 68 65 |/* check| for the|
|00001ba0| 20 27 26 61 75 78 27 20 | 6b 65 79 77 6f 72 64 20 | '&aux' |keyword |
|00001bb0| 2a 2f 0d 20 20 20 20 69 | 66 20 28 63 6f 6e 73 70 |*/. i|f (consp|
|00001bc0| 28 66 61 72 67 73 29 20 | 26 26 20 63 61 72 28 66 |(fargs) |&& car(f|
|00001bd0| 61 72 67 73 29 20 3d 3d | 20 6b 5f 61 75 78 29 0d |args) ==| k_aux).|
|00001be0| 09 77 68 69 6c 65 20 28 | 28 66 61 72 67 73 20 3d |.while (|(fargs =|
|00001bf0| 20 63 64 72 28 66 61 72 | 67 73 29 29 20 21 3d 20 | cdr(far|gs)) != |
|00001c00| 4e 49 4c 20 26 26 20 63 | 6f 6e 73 70 28 66 61 72 |NIL && c|onsp(far|
|00001c10| 67 73 29 29 0d 09 20 20 | 20 20 78 6c 62 69 6e 64 |gs)).. | xlbind|
|00001c20| 28 63 61 72 28 66 61 72 | 67 73 29 2c 4e 49 4c 29 |(car(far|gs),NIL)|
|00001c30| 3b 0d 0d 20 20 20 20 2f | 2a 20 6d 61 6b 65 20 73 |;.. /|* make s|
|00001c40| 75 72 65 20 74 68 65 20 | 63 6f 72 72 65 63 74 20 |ure the |correct |
|00001c50| 6e 75 6d 62 65 72 20 6f | 66 20 61 72 67 75 6d 65 |number o|f argume|
|00001c60| 6e 74 73 20 77 65 72 65 | 20 73 75 70 70 6c 69 65 |nts were| supplie|
|00001c70| 64 20 2a 2f 0d 20 20 20 | 20 69 66 20 28 66 61 72 |d */. | if (far|
|00001c80| 67 73 20 21 3d 20 61 61 | 72 67 73 29 0d 09 78 6c |gs != aa|rgs)..xl|
|00001c90| 66 61 69 6c 28 66 61 72 | 67 73 20 3f 20 22 74 6f |fail(far|gs ? "to|
|00001ca0| 6f 20 66 65 77 20 61 72 | 67 75 6d 65 6e 74 73 22 |o few ar|guments"|
|00001cb0| 20 3a 20 22 74 6f 6f 20 | 6d 61 6e 79 20 61 72 67 | : "too |many arg|
|00001cc0| 75 6d 65 6e 74 73 22 29 | 3b 0d 7d 0d 0d 2f 2a 20 |uments")|;.}../* |
|00001cd0| 69 73 6b 65 79 77 6f 72 | 64 20 2d 20 63 68 65 63 |iskeywor|d - chec|
|00001ce0| 6b 20 74 6f 20 73 65 65 | 20 69 66 20 61 20 73 79 |k to see| if a sy|
|00001cf0| 6d 62 6f 6c 20 69 73 20 | 61 20 6b 65 79 77 6f 72 |mbol is |a keywor|
|00001d00| 64 20 2a 2f 0d 4c 4f 43 | 41 4c 20 69 6e 74 20 69 |d */.LOC|AL int i|
|00001d10| 73 6b 65 79 77 6f 72 64 | 28 73 79 6d 29 0d 20 20 |skeyword|(sym). |
|00001d20| 4e 4f 44 45 20 2a 73 79 | 6d 3b 0d 7b 0d 20 20 20 |NODE *sy|m;.{. |
|00001d30| 20 72 65 74 75 72 6e 20 | 28 73 79 6d 20 3d 3d 20 | return |(sym == |
|00001d40| 6b 5f 6f 70 74 69 6f 6e | 61 6c 20 7c 7c 20 73 79 |k_option|al || sy|
|00001d50| 6d 20 3d 3d 20 6b 5f 72 | 65 73 74 20 7c 7c 20 73 |m == k_r|est || s|
|00001d60| 79 6d 20 3d 3d 20 6b 5f | 61 75 78 29 3b 0d 7d 0d |ym == k_|aux);.}.|
|00001d70| 0d 2f 2a 20 78 6c 73 61 | 76 65 20 2d 20 73 61 76 |./* xlsa|ve - sav|
|00001d80| 65 20 6e 6f 64 65 73 20 | 6f 6e 20 74 68 65 20 73 |e nodes |on the s|
|00001d90| 74 61 63 6b 20 2a 2f 0d | 4e 4f 44 45 20 2a 78 6c |tack */.|NODE *xl|
|00001da0| 73 61 76 65 28 6e 29 0d | 20 20 4e 4f 44 45 20 2a |save(n).| NODE *|
|00001db0| 6e 3b 0d 7b 0d 20 20 20 | 20 4e 4f 44 45 20 2a 2a |n;.{. | NODE **|
|00001dc0| 6e 70 74 72 2c 2a 6f 6c | 64 73 74 6b 3b 0d 0d 20 |nptr,*ol|dstk;.. |
|00001dd0| 20 20 20 2f 2a 20 73 61 | 76 65 20 74 68 65 20 6f | /* sa|ve the o|
|00001de0| 6c 64 20 73 74 61 63 6b | 20 70 6f 69 6e 74 65 72 |ld stack| pointer|
|00001df0| 20 2a 2f 0d 20 20 20 20 | 6f 6c 64 73 74 6b 20 3d | */. |oldstk =|
|00001e00| 20 78 6c 73 74 61 63 6b | 3b 0d 0d 20 20 20 20 2f | xlstack|;.. /|
|00001e10| 2a 20 73 61 76 65 20 65 | 61 63 68 20 6e 6f 64 65 |* save e|ach node|
|00001e20| 20 2a 2f 0d 20 20 20 20 | 66 6f 72 20 28 6e 70 74 | */. |for (npt|
|00001e30| 72 20 3d 20 26 6e 3b 20 | 2a 6e 70 74 72 20 21 3d |r = &n; |*nptr !=|
|00001e40| 20 4e 55 4c 4c 3b 20 6e | 70 74 72 2b 2b 29 20 7b | NULL; n|ptr++) {|
|00001e50| 0d 09 72 70 6c 61 63 61 | 28 2a 6e 70 74 72 2c 4e |..rplaca|(*nptr,N|
|00001e60| 49 4c 29 3b 0d 09 72 70 | 6c 61 63 64 28 2a 6e 70 |IL);..rp|lacd(*np|
|00001e70| 74 72 2c 78 6c 73 74 61 | 63 6b 29 3b 0d 09 78 6c |tr,xlsta|ck);..xl|
|00001e80| 73 74 61 63 6b 20 3d 20 | 2a 6e 70 74 72 3b 0d 20 |stack = |*nptr;. |
|00001e90| 20 20 20 7d 0d 0d 20 20 | 20 20 2f 2a 20 72 65 74 | }.. | /* ret|
|00001ea0| 75 72 6e 20 74 68 65 20 | 6f 6c 64 20 73 74 61 63 |urn the |old stac|
|00001eb0| 6b 20 70 6f 69 6e 74 65 | 72 20 2a 2f 0d 20 20 20 |k pointe|r */. |
|00001ec0| 20 72 65 74 75 72 6e 20 | 28 6f 6c 64 73 74 6b 29 | return |(oldstk)|
|00001ed0| 3b 0d 7d 0d 00 00 00 00 | 00 00 00 00 00 00 00 00 |;.}.....|........|
|00001ee0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001ef0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001f00| 00 00 01 00 00 00 01 16 | 00 00 00 16 00 00 00 d4 |........|........|
|00001f10| 20 5f a0 29 28 50 41 ef | 00 04 22 4d b3 c8 67 00 | _.)(PA.|.."M..g.|
|00001f20| 00 08 42 58 60 00 ff f6 | 4e ad 09 ea 41 ed 09 ea |..BX`...|N...A...|
|00001f30| 08 78 6c 65 76 61 6c 2e | 63 65 02 00 00 00 00 00 |.xleval.|ce......|
|00001f40| 00 00 00 00 00 00 01 00 | 00 c0 00 40 0d 28 00 00 |........|...@.(..|
|00001f50| 00 00 00 00 00 00 00 00 | 00 00 01 00 00 c0 00 40 |........|.......@|
|00001f60| 0d 28 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.(......|........|
|00001f70| 00 00 98 7f 66 e8 00 00 | 1e 54 00 00 01 ea 4a 40 |....f...|.T....J@|
|00001f80| 67 0e 48 6c 00 36 4e ba | 64 14 58 8f 4e ba 76 24 |g.Hl.6N.|d.X.N.v$|
|00001f90| 4e ba 55 ba 48 6e ff b8 | 4e ba 24 76 58 8f 2f 2d |N.U.Hn..|N.$vX./-|
|00001fa0| f5 36 3f 3c 00 08 48 6e | ff b8 4e ba 24 12 de fc |.6?<..Hn|..N.$...|
|00001fb0| 00 0a 48 6e ff be 4e ba | 69 06 58 8f 0c 40 00 00 |..Hn..N.|i.X..@..|
|00001fc0| 66 0e 42 67 42 67 48 6c | 00 52 4e ba 00 a2 50 8f |f.BgBgHl|.RN...P.|
|00001fd0| 42 a7 48 6e ff ae 4e ba | 2d ca 50 8f 30 3c 00 01 |B.Hn..N.|-.P.0<..|
|00001fe0| 67 50 48 6e ff be 4e ba | 68 d6 58 8f 4a 40 67 10 |gPHn..N.|h.X.J@g.|
|00001ff0| 20 6d f5 1e 42 a8 00 06 | 20 6d f5 1a 42 a8 00 06 | m..B...| m..B...|
|00002000| 00 00 00 0a 00 09 06 4d | 6f 6e 61 63 6f 0e 00 00 |.......M|onaco...|
|00002010| 00 04 00 06 00 08 00 00 | 01 00 00 00 01 16 00 00 |........|........|
|00002020| 00 16 00 00 00 d4 00 00 | c1 1c 00 7a 00 00 00 1c |........|...z....|
|00002030| 00 46 00 01 45 46 4e 54 | 00 00 00 12 45 54 41 42 |.F..EFNT|....ETAB|
|00002040| 00 00 00 1e 03 eb 00 00 | 00 00 00 00 00 01 5a f0 |........|......Z.|
|00002050| 03 ec 00 47 00 00 00 0e | 00 01 5b 0c 46 4f 42 4a |...G....|..[.FOBJ|
|00002060| 00 fe 06 ec 00 40 01 80 | 00 40 01 82 00 40 01 84 |.....@..|.@...@..|
|00002070| 00 40 01 86 00 40 01 88 | 00 40 01 8a 00 40 01 8c |.@...@..|.@...@..|
|00002080| 00 fe 1f 66 00 40 12 a0 | 00 40 01 92 00 40 01 94 |...f.@..|.@...@..|
|00002090| 00 40 01 94 00 40 01 94 | 00 40 01 94 00 40 01 94 |.@...@..|.@...@..|
|000020a0| 00 40 01 46 4f 42 4a 00 | fe 06 ec 00 40 01 80 00 |.@.FOBJ.|....@...|
|000020b0| 40 01 82 00 40 01 84 00 | 40 01 86 00 40 01 88 00 |@...@...|@...@...|
|000020c0| 40 01 8a 00 40 01 8c 00 | fe 1f 66 00 40 12 a0 00 |@...@...|..f.@...|
|000020d0| 40 01 92 00 40 01 94 00 | 40 01 94 00 40 01 94 00 |@...@...|@...@...|
|000020e0| 40 01 94 00 40 01 94 00 | 40 01 00 00 00 00 00 00 |@...@...|@.......|
|000020f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+